<template>
	<view class="homeLayout pageBg">
		<custom-nav-bar title="推荐"></custom-nav-bar>
		
		<view class="banner">
			
			<swiper 
				indicator-dots
				indicator-color="rgba(255,255,255,0.5)"
				indicator-active-color="#fff"
				autoplay
				circular
			>
				<swiper-item v-for="item in bannerList" :key="item._id">
					<image :src="item.picurl" mode="aspectFill"></image>
				</swiper-item>
				
				
			</swiper>
			
		</view>
		
		<view class="notice">
			
			<view class="left">
				<uni-icons 
					type="sound-filled" 
					size="20"
					color="#28b389"
				></uni-icons>
				<text class="text">公告</text>
			</view>
			<view class="center">
				<swiper
					vertical
					autoplay
					interval="1500"
					duration="300"
					circular
				>
					
					<swiper-item v-for="item in noticeList" :key="item._id">
					<!-- <swiper-item v-for="item in 2" > -->
						<navigator :url="`/pages/notice/detail?id=${item._id}`">{{item.title}}</navigator>
						<!-- <navigator url="/pages/notice/detail">风夏练手项目</navigator> -->
					</swiper-item>
					
				</swiper>
			</view>
			<view class="right">
				<uni-icons
					type="right" 
					size="20"
					color="#28b389"
				></uni-icons>
			</view>
			
		</view>
	
		<view class="select">
			<common-title>
				<template #name>每日推荐</template>
				<template #custom>
					<view class="date">
						<uni-icons type="calendar" size="18" color="#28b389"></uni-icons>
						<view class="text">
							<uni-dateformat :date="Date.now()" format="dd日"></uni-dateformat>
							
						</view>
					</view>
				</template>
			</common-title>
			<view class="content">
				
				<scroll-view scroll-x >
					<view class="box" v-for="item in randomList" :key="item._id" @click="goPreview(item._id)">
						<image :src="item.smallPicurl" mode="aspectFill"></image>
					</view>
				</scroll-view>
				
			</view>
		</view>
		
		<!-- 专题精选 -->
		<view class="theme">
			<common-title>
				<template #name>专题精选</template>
				<template #custom>
					<navigator url="/pages/classify/classify" open-type="reLaunch" class="more">More+</navigator>
				</template>
			</common-title>
			
			<view class="content">
				<theme-item 
					v-for="item in classifyList" 
					:key="item._id"
					:item="item"
				></theme-item>
				<theme-item :isMore="true"></theme-item>
			</view>
		</view>
		
		
	</view>
</template>

<script setup lang="ts">
//引入
	import { ref } from 'vue';
	import {onShareAppMessage,onShareTimeline} from "@dcloudio/uni-app"
	import {apiGetBanner,apiGetDayRandom,apiGetNotice,apiGetClassify} from '@/api/apis'

//数据
	const bannerList = ref([])
	const randomList = ref([])
	const noticeList = ref([])
	const classifyList = ref([])
	
//方法
	
	//获取公告
	const getNotice =async()=>{
		let res:any = await apiGetNotice({select:true})
		noticeList.value = res.data
	}

	//获取每天的图
	const getDayRandom = async()=>{
		let res:any = await apiGetDayRandom()
		randomList.value = res.data
	}
	
	//获取banner图
	const getBanner = async ()=> {
		let res:any = await apiGetBanner()
		bannerList.value = res.data
	}
	
	//专题精选
	const getClassify = async ()=> {
		let res:any = await apiGetClassify({
			select:true
		})
		classifyList.value = res.data
	}
		
	
	
	//跳转到预览页面
	const goPreview = (id)=>{
		console.log(randomList);
		uni.setStorageSync("storyClassList",randomList.value);
		uni.navigateTo({
			url:"/pages/perview/perview?id="+id
		})
	}
	
	//分享
	onShareAppMessage((e)=>{
		return {
			title:"风夏个人练手项目",
			path:"/pages/index/index"
		}
	})
	
	
	//分享朋友圈
	onShareTimeline(()=>{
		return {
			title:"风夏个人练手项目",
			imageUrl:'/static/images/logo.png'
		}
		
	})
	
	//调用
	getBanner()
	getDayRandom()
	getNotice()
	getClassify()
</script>

<style lang="scss" scoped>
	.homeLayout{
		
		.banner{
			width: 750rpx;
			padding: 30rpx 0;
			
			swiper{
				width: 750rpx;
				height: 340rpx;
				
				&-item{
					width: 100%;
					height: 100%;
					padding: 0 30rpx;
					image{
						width: 100%;
						height: 100%;
						border-radius: 10rpx;
					}
				}
			}
		}
		.notice{
			width: 690rpx;
			height: 80rpx;
			line-height: 80rpx;
			background-color: #f9f9f9;
			margin: 0 auto;
			border-radius: 80rpx;
			display: flex;
			.left{
				width: 140rpx;
				display: flex;
				align-items: center;
				justify-content: center;
				.text{
					color: $brand-theme-color;
					font-weight: 600;
					font-size: 28rpx
				}
			}
			.right{
				width: 70rpx;
				display: flex;
				align-items: center;
				justify-content: center;
			}
			.center{
				flex: 1;
				swiper{
					height: 100%;
					swiper-item{
						height: 100%;
						font-size: 30rpx;
						color: #666;
						overflow: hidden;
						white-space: nowrap;
						text-overflow: ellipsis;
					}
				}
			}
		}
		.select{
			padding-top: 50rpx;
			.content{
				width: 720rpx;
				margin-left: 30rpx;
				margin-left:30rpx;
				scroll-view{
					white-space: nowrap;
					.box{
						width: 200rpx;
						height: 430rpx;
						display: inline-block;
						margin-right: 15rpx;
						image{
							width: 100%;
							height: 100%;
							border-radius: 10rpx;
						}
					}
					.box:last-child{
						margin-right: 30rpx;
					}
				}
			}
			.date{
				color: $brand-theme-color;
				display: flex;
				align-items: center;
				.text{
					margin-left: 5rpx;
				}
			}
		}
		.theme{
			padding-top: 50rpx;
			padding-bottom: 50rpx;
			.more{
				font-size: 32rpx;
				color: #888;
			}
			.content{
				margin-top: 30rpx;
				padding: 0 30rpx;
				display: grid;
				gap: 15rpx;
				grid-template-columns: repeat(3,1fr);
				
			}
		}
	}
</style>
